import store from '@/store'
import axios from 'axios'
import router from '@/router'
import { Message } from 'element-ui'

export const baseURL = 'http://big-event-vue-api-t.itheima.net'

const myAxios = axios.create({
  baseURL: baseURL
})
// 定义请求拦截器
// api里每次调用request都会先走这个请求拦截器
myAxios.interceptors.request.use(function(config) {
  // config配置对象(要请求后台的参数都在这个对象上)
  // 在请求前会触发一次，这个return交给axios源码内，根据配置项发起请求

  // 在发起时，统一携带请求头Authorization和token值
  // 判断，登录页面和注册页面，vuex里无token，而且登录接口和注册接口也不需要携带token
  if (store.state.token) {
    config.headers.Authorization = store.state.token
  }
  return config
}, function(error) {
  // 请求发起前的代码，如果有异常报错，会直接进入这里
  // 返回一个拒绝状态的Promise对象(axios留在原地的Promise对象状态就为失败结果为error变量值)
  // 此函数类似catch函数( )里return
  // 口诀: return非Promise对象值， 会作为成功的结果，返回给下一个Promise对象(axios留在原地)
  // 口诀: returnPromise对象，这个Promise对象状态，返回给下一个Promise对象
  // Promise . reject() 原地留下一个新的Promise对 象(状态为失败) 它是Promise的类 方法reject()

  return Promise.reject(error)
  /** 等同于
   * return new Promise((resolve, reject) => {
   * reject(error)
   * })
   */
})

myAxios.interceptors.response.use(function(response) {
  return response
}, function(error) {
  if (error.response.status === 401) {
    store.commit('updateToken', '')
    store.commit('updateUserInfo', {})
    router.push('/login')
    Message.error('用户身份已过期！！！')
  }
  return Promise.reject(error)
})
// 导出axios自定义函数
export default myAxios
